草庐IT

C++ ostringstream 奇怪的行为

全部标签

c++ - 未定义行为的意义何在?

这个问题在这里已经有了答案:Undefined,unspecifiedandimplementation-definedbehavior(9个回答)关闭5年前。我可以理解保留一些已定义的实现,以便实现它的特定人员知道最好发生什么,但为什么某些事情会成为未定义的行为?为什么不直接说,还有什么是实现定义的?

c++ - 尝试在 C++ 中转换结构时出现奇怪的错误消息

在Linux上使用C++,我只是相当愚蠢地写了这个:structin_addrip_addr=((structsockaddr_in)socket_addr).sin_addr;而不是预期的:structin_addrip_addr=((structsockaddr_in*)&socket_addr)->sin_addr;给我这个错误:"error:nomatchingfunctionforcallto‘sockaddr_in::sockaddr_in(sockaddr&)"我知道为什么会出现错误(我正在尝试转换结构),但我不明白为什么错误消息说明了它的作用。有人可以解释一下吗?

c++ - 为什么 offsetof 实现在 C 和 C++ 上有奇怪的不同?

我打开了stddef.h并看到了这个:#ifdefined_MSC_VER&&!defined_CRT_USE_BUILTIN_OFFSETOF#ifdef__cplusplus#defineoffsetof(s,m)((size_t)&reinterpret_cast((((s*)0)->m)))#else#defineoffsetof(s,m)((size_t)&(((s*)0)->m))#endif#else#defineoffsetof(s,m)__builtin_offsetof(s,m)#endif在__cplusplus的分支中(如果是C++编译器)有一个非常奇怪的实现,

c++ - 带有 unsigned char 的 for 循环给出了意想不到的行为

我正在练习面试问题,但很难回答这个基本问题:Howmanytimeswillthisloopexecute?unsignedcharhalf_limit=150;for(unsignedchari=0;i我的想法是,由于unsignedint仅达到255,它将永远执行,因为当我在unsignedchar为255时增加它时它会恢复为0?然而,这种想法是错误的,更奇怪的是,这是cout给我的输出:!"#$%&'()*+,-./0123456789:;?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~�������

c++ - std::ostringstream 问题

我可以std::ostringstreamoss;oss为什么我不能:((std::ostringstream())谢谢! 最佳答案 运算符返回基类型ostream,而str成员函数仅存在于派生类型上ostringstream. 关于c++-std::ostringstream问题,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/2196121/

c++ - 非虚拟析构函数的未定义行为 - 这是一个现实世界的问题吗?

考虑以下代码:classA{public:A(){}~A(){}};classB:publicA{B(){}~B(){}};A*b=newB;deleteb;//undefinedbehaviour我的理解是,C++标准规定删除b是未定义的行为-即,任何事情都可能发生。但是,在现实世界中,我的经验是~A()总是被调用,并且内存被正确释放。如果B引入任何具有自己的析构函数的类成员,它们将不会被调用,但我只对上面的简单情况感兴趣,其中使用继承可能会修复一个类方法中的错误源代码不可用。显然,这不会是您在非平凡情况下想要的,但它至少是一致的。对于显示的代码,您是否知道任何C++实现都不会发生上

C++ Int 到 String 通过使用 ostringstream 或 stringstream

我一直在使用stringstream将Integer转换为String,但后来我意识到可以使用ostringstream完成相同的操作。当我使用.str()时,它们之间有什么区别?另外,有没有更有效的方法将整数转换为字符串?示例代码://usingostringstreamostringstreams1;inti=100;s1 最佳答案 还有第三个你没有提到,istringstream,你不能使用(你可以,但它会有所不同,你不能将转换为istringstream)。stringstream既是ostringstream和一个istr

c++ - 奇怪的 printf 行为

std::vectorv;for(size_ti=init;i输出:4095000我不明白为什么这个printf会这样?init或pageSize都不为0。我知道%d对unsignedlonglong无效,但令我困扰的是当参数的顺序改变时printf的行为改变。 最佳答案 NeitherinitorpageSizeis0.%d也不是适合64位值的格式字符串说明符,我敢打赌:-)很有可能,您需要使用%ld(如果您的longs是64位)或%lld(如果您的longlongs是64位)或来自最新C标准的固定宽度说明符宏,我永远无法记住它们

c++ - 如何通过多重继承实现多态行为?

我从未使用过多重继承,但在最近阅读它时,我开始思考如何在我的代码中实际使用它。当我正常使用多态性时,我通常通过创建声明为基类指针的新派生实例来使用它,例如BaseClass*pObject=newDerivedClass();这样我在派生类上调用虚函数时就能得到正确的多态行为。通过这种方式,我可以拥有不同多态类型的集合,这些类型通过它们的虚函数来管理自己的行为。在考虑使用多重继承时,我在考虑相同的方法,但如果我有以下层次结构,我会怎么做classA{virtualvoidfoo()=0;};classB:publicA{virtualvoidfoo(){//implementation

c++ - boost 属性 write_json 不正确的行为

我正在为Boost属性树编写一个JSON包装器。目前的重点是将生成的JSON写入字符串或文件。使用boost::property_tree::json_parser::write_json(ss,*pt)生成的属性树被写成一个字符串。但是这个方法不理解什么是真、假、空或数字。一切都转换为字符串。阅读Boost文档,这是库的一个限制。有什么办法可以修改这种行为吗? 最佳答案 Link此链接中包含问题的修复程序。它涉及更改boost代码,因此我尝试了另一种选择。我的解决方案涉及正则表达式:std::stringJSONObject::t